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specification 



Modular Scalable Switching Networks 

5 Field of the Invention 

The present invention generally relates to interconnection networks, and in particular 
to a scalable switching fabric architecture allowing for the building of large switching 
networks from a common module. 

10 BACKGROUND OF THE INVENTION 

Fig. 1 shows the structure of a crossbar matrix 1 in which input lines 10 and output 

lines 20 are shown to be situated perpendicular to each other and are further shown to be 

coimected at respective crosspoints. The crossbar matrix 1 is non-blocking - any input line 

^3 may be connected to any output line without blocking other input - to- output connections. 

HS For a N X N square crossbar wherein the number of input lines and output lines are the same, 

W (N representing the number of input lines and the number of outpxit lines) the complexity 

'' :,| grows by N^. In addition to complexity in monolithic IC implementation, the package pin 

' constraints will limit the number of input and output lines (N). 

S3 Multi-stage Interconnection Networks (MIN) enable building large switches from 

go smaller switches in a structured manner. A three stage (stages 120, 130 and 140) network is 

JL; shown in Figure 2. The network of Figure 2 is a class of networks based on the Clos network. 

13 This type of network belongs to so-called constant stage networks or limited stage networks. 

In Fig. 2, a Clos network 100 is shown with N input lines 1 10 and N output lines 150. The N 

input lines 1 10 are divided into m groups 111,112,..., 1 19,in Fig.2 we are showing 'n' rather 

25 than 'm', each group consisting of n inputs (N = m * n). Each group of n inputs is coimected 

to a (n X k) switch 121, 122, ... 129. The first stage 120 (also called input stage) consists of m 

groups of (n x k) switches 121, 122, 129, each having n input lines (not shown) and k 

output lines (not shown). The second stage 130 (also called middle stage) consists of k 

switches 131, 132, .., 139 of size (m x m). The third stage 140 (also called the output stage) 

30 consists of m (k x n) switches 141, 149. The N output lines 150 include the outputs 151, 

152, 159 of the m switches 141, 142, 149, respectively, in the output stage 140. 

With reference to Fig. 2, the outputs 161, 162, .., 169 of the first stage 120 each 

consist of k lines which will be denoted by Oly (1< i <m, 1 <j < k), the i index identifies the 
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switch in the 1^ stage and the index j identifies one of the k output lines of the 1^ stage of the 
switch. The input lines 171 , 172, 179 of the second stage 130 each consist of m lines 
denoted by I2ij (1 < i < k, 1< j < m) the index i identifies one of the k switches and the index j 
identifies one of the m input lines of the switch. The output lines 181, 182, 189 of the 
5 second stage 130 each consist of m lines denoted by 02ij (1 < i <k, 1< j <m) the index i 
identifies one of the k switches and the index j identifies one of the m output lines. The input 
lines 191, 192, 199 of the third stage 140 each consist of k lines denoted by I3ij (1< i < m, 
1< j < k) the index i identifies one of the m switches and the index j identifies one of the k 
input lines of the switch. The output lines 151, 152, 159 of the third stage 140 each consist 

10 of n lines denoted by 03ij (1< i < m, 1< j < n) the index i identifies one of the m switches and 
the index j identifies one of the n outputs of the switch. The interconnection between stages is 
as follows: 

Output j of switch i in the first stage (Olij) is connected to input i of switch j in the 
% 3 second stage (I2j i). 

Output j of switch i in the second stage (02ij) is connected to input i of switch j in the 

11 third stage (I3ji). 

' J The Clos network 100 of Fig. 2 is denoted as a v(k, n, m). To avoid blocking 

I problems, the design parameters of the network must be selected properly. Clos has shown 
1% that the three stage network of Fig. 2 is strictly non-blocking if k > (2n -1). The complexity of 

switch can be reduced if existing connections can be broken and remade without loss of data 
13 in order to establish additional new connections. This type of switch is called a Rearrangeably 

Nonblocking Switch. The three stage network of Figure 2 is rearrangeably nonblocking if k > 

n. 

The input stage 120 and output stages 140 of a Clos network consist of m switches. 
25 The middle stage 130 of network 100 consists of k switches. The prior art suggest systems 
with integrated input and output stages and separate middle stage. The problem with prior art 
is that the structure is not modular, that is the v(k, n, m) network of Fig. 2 can not be 
constructed fi:om m identical modules. 

Therefore, there is a need for constructing a Clos network v(k, n, m) from m identical 
30 modules, fiirthermore there is a need for constructing a modular and scalable Clos networks 
v(k, n, m), wherein network of different sizes (different values of m) can be constructed from 
m identical modules and allows building larger networks fi*om a module by adding such 
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modules as needed. The advantage of a modular structure is that it allows integration into a 
single module or monolithic Integrated Circuit (IC). The advantages of modular and scalable 
structure is that it allows building networks of different sizes from the same module or IC. 



5 SUMMARY OF THE INVENTION 

Briefly, an embodiment of the present invention includes an expandable network 
comprising of modules having switches wherein the modules are identical. Furthermore, a 
method for building a network with varying sizes (different values of m) from a common 
module is disclosed. 

1 0 These and other features and advantages of the present invention will become well 

understood upon examming the figures and reading the following detailed description of the 
invention. 

IN THE DRAWINGS 

' f Fig. 1 shows a switch based on crossbar matrix 

5 Fig. 2 shows an example of Clos network of prior art. 

m Figs. 3 illustrates a Clos network in accordance with an embodiment of the present 

n invention, 

1'^ Figs. 4 illustrates a Clos network in accordance with an embodiment of the present 

13 invention. 

io 

m DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

n Referring now to Fig. 3, a Clos network v(k, n, m) 200 is shown in accordance with an 

embodiment of the present mvention. The network 200 includes N input lines 210 and N 
output lines 250. The N input Imes 210 are divided into m groups 211, 212, ..,,219, each 

25 group consisting of n input lines (N = m * n). Each group of n input lines is connected to a (n 
X k) switch 221, 222, ... 229. The first stage 220 (also called input stage) consists of m 
groups of (n x k) switches 221, 222, 229, each having n inputs 211, 212, 219 and k 
outputs 261, 262, .., 269. The second stage 230 (also called middle stage) consists of m 
switches 231, 232, 239 of size (k' x k') each having k' inputs 271, 272, .., 279 and k' 

30 outputs 281, 282, . . 289. The third stage 240 (also called the output stage) consists of m (k x 
n) switches 241, 249 each having k inputs 291, 292, .., 299 and n outputs 251, 252, 
...,259. The N output lines 250 consist of the outputs 251, 252, .., 259 of the m switches 241, 
242, .., 249 in the output stage 240. 
Nemazie-01 3 



The input stage 220, the middle stage 230^ and output stages 240 of Clos network 200 
of the present invention all consist of m switches. The switches 221, 231, and 241 are 
grouped together and are included in the module 201. In a similar manner, the other modules 
202, 209 include the grouping of switches (222, 232, 242), (229, 239, 249), 
5 respectively. The network 200 is built from identical modules 201, 202, 209 where each 
module includes groups of switches (221, 231, 241), (222, 231, 242), (229, 239, 249). 
Each module includes three switches an input switch of size (n x k), a middle switch of size 
(k' X k') and an output switch of size (k x n) 

A discussion is now presented regarding the selection of the parameter k'. With 
1 0 reference to Fig. 2, the second stage 130 of network 100 consists of k (m x m) switches. The 
second stage 230 of network 200 consists of m (k' x k') switches 231, 232, 239. 

With each (k' x k') switch, a network of q (m x m) switches, can be built wherein q is 
the quotient of dividing k' by m (q = Q(k7m) where Q (x/y) denotes the quotient of x divided 
by y). The m*q inputs and outputs of (k' x k') switch are used and the (k' - m*q) remaining 
^ inputs and outputs are unused. The minimum number of equivalent (m x m) switches that is 
|;3 required in the second stage is k. Since in the second stage of network 200, there are m (k' x 
r J k') switches, a network of m*q (m x m) switches can be built, therefore parameter k' must be 
' selected such that : 

O m * Q (k'/m) > k Eq. 1 

p& The connectivity of the middle stage 230 of the network 200 is now described, A simple way 

;j of describing the connectivity of the middle stage 230 is in terms of an equivalent virtual (m x 

C3 m) switch. That is, the middle stage 230 is first transformed, into an equivalent virtual k (m x 

m) switches and the connectivity of the equivalent virtual k (m x m) switches is the same as 

that described previously. There are m (k' x k') switches 231, 232, 239 and as described 

25 above, with each (k' x k') switch, a network of q (m x m) switches is built. Starting with the 

first switch 231, the q*m input and output lines are assigned to the q equivalent (m x m) 

switches and any remaining input and output lines of the switch are unused. The virtual (m x 

m) switches are labeled 1, .., q, the assigned input lines are labeled Ky. The index i identifies 

one of the virtual switches and the index j identifies one of the m input lines of the virtual 

30 switch, the assigned output lines are labeled 02ij. The index i identifies one of the virtual 

switches and the index j identifies one of the m outputs. The same process is repeated for the 

second switch 232, the virtual (m x m) switches are labeled (q+1), .., 2q, the assigned inputs 

and outputs are labeled I2ij and 02ij respectively similar to the first switch. This process is 
Nemazie-01 4 



repeated until the last switch 239. With k' satisfying Eq. 1, then at least k equivalent (m x m) 
virtual switches is constructed. The inputs lines of said virtual switches are labeled Ky (1 < i 
< k, 1< j < m) where the index i identifies one of the k virtual (m x m) switches and the index 
j identifies one of the m input lines of the switch. The output Imes of the virtual switches are 
5 labeled 02ij (1 < i <k, 1< j <m). The index i identifies one of the k (m x m) virtual switches 
and the index j identifies one of the m outputs. The interconnection between stages is as 
follows: 

Output j of switch i in the fu-st st^e (Olij) is connected to input i of virtual switch j in 
the second stage (I2ji). 

1 0 Output j of virtual switch i in the second stage (02ij) is connected to input i of switch 

j in the third stage (I3ji). 

We have disclosed a v(k, n, m) switching network using m identical modules and a 
method of building a v(k, n, m) switching network from m identical modules. 
3l Next, methods for building a scalable v(k, n, m) switching network from a common 

''|5 module will be disclosed. The method includes constructing a switching network 200 from 
5? common module 201 and selecting parameter k, k' and specifying a subset of integers ^ 
H such that networks with values of m belonging to ^ (m € ^ can be constructed with the 
I same common module. 

\i Let the set of divisors of k be denoted by ^ = { m| m divides k} . If k' is selected to 

120 be equal to k (k'= k), it is obvious that m*Q(k'/m)=k for all m e and Eq. 1 is satisfied, 
i 3 Please note that the set ^ at least includes 1 , and k. Therefore one method is as follows: 
k' = k and ={ ml m divides k} (Al) 

Let mi, m2, .. denote divisors of k other than 1, and k. If k is prime then the set {mj} is 
empty. With k' and ^ according to Al then Eq. 1 is satisfied for all (m e .^k), and network 
25 of size {n, (mi)*n, (m2)*n, (k)*n}can be constructed from identical modules 201 as 
described previously. 

Another method is as follows: 

k' = k= a', and { m| m = a' (1< r < s)} (A2) 
With k' and ^ according to A2 then Eq. 1 is satisfied for all (m e .Jf), and network 
30 of size {n, (a^n, (a^)*n, (a')*n}can be constructed from identical modules 201 as 
described previously. In practice, integer a is typically two (2) and k= 2^ and m = 2'' (1< r < 
s). For example, select k' = k = 32 = 2\ Then networks of size n, {2^Tn, (2^)*n, (2^)*n, 
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(2^)*n and (2^)* n can be constructed from identical modules 201 as described in the 
embodiment of present invention. 

The above method is an exponentially scalable solution. The exponentially scalable 
method is perfectly acceptable method in certain applications. We nov^ present a linearly 
5 scalable method. 

Another method to satisfy Eq, 1 is as follows: 
k'=k + (M-l), ^={m|l<m <M}, (A3) 
With k' and ^ according to A2 then Eq. 1 is satisfied for all (m g To 
demonstrate this let k =q*m + r (0 < r < m-1), and let k'= k + (M-1), 
10 q*m<k<(q+ l)*m 

If k is divisible by m then r =0, and m*Q(kVm) = k and Eq. 1 is satisfied. 
If k is not divisible by m then 1 < r < (m-1), and (k + (m -1)) > (q + l)*m, 
Since m < M therefore k'- k + (M - 1) > (q + l)*m, and Q(k7m) > (q + 1), 
^3 therefore 

,1:5 m*Q(kVm) > (q + l)*m > k and Eq. 1 is satisfied. 

f -F-i 

J; J With k' according to A3 then you can build a network of size n, 2n, 3n , 4n, . . M^n^ 

^ j that is you can build a linearly scalable Clos network upto M*n from identical modules 201 
s as described in the embodiment of present invention. 

7^ Several methods for constructing a scalable modular Clos network have been 

^3 disclosed. Although the method has been described in terms of specific values for {k, k\ 
13 different values of {k, k', that satisfy Eq. 1 are considered to fall within the true spirit and 
scope of the invention. 

In the method described, some inputs and outputs, specifically (k' - m*q) where 
q ^ Q(kVm), of the 2"^ stage of module 201 will be unused since there is not enough inputs 
25 and outputs to make an m x m switch. In another embodiment, the parameter k' is selected to 
be equal to k. After assigning the m*q inputs and outputs, the remaining (k - m*q) inputs of 
the switch and the first ((m+l)*q - k) inputs and outputs of the next switch are assigned to 
next virtual (m x m) switch, the remaining inputs and output of the next switch are grouped 
into groups of m inputs and outputs, forming complete virtual (m x m) switches. With 
30 remaining inputs and outputs, the same process is repeated. Since there is no unused inputs of 
outputs, k'==k, however in this system, some of the virtual (m x m) switches are split between 
two modules. In order to implement the split virtual (m x m) switches in the middle switch, 
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split switches. Fig. 4 shows an embodiment 300 according to the above. The conamon module 
302 includes a (n x k) switch, a l""^ (k, k) switch, a 3'^ (k x n) switch, and a first M bi- 
directional lines 401 and a 2^^ M bi-directional lines 402 between adjacent modules for 
implementing split switches. It should be noted that for the first and last modules, one of the 

5 M-bidirectional lines will be unused. A Clos networks v(k, n, m) of size n, 2n, 3n , 4n, 
M*n, can be constructed fi-om module 302 as described above. Although the above 
embodiment has been described in terms of a specific method to implement split switches 
between adjacent modules other methods of implementing split switches between adjacent 
modules fall within the true spirit and scope of the invention. 

0 Although the present invention has been described in terms of specific embodiments it 

is anticipated that alterations and modifications thereof will no doubt become apparent to 
those skilled in the art. It is therefore intended that the following claims be interpreted as 
covering all such alterations and modifications as fall within the true spirit and scope of the 
invention. 

5 

What I claim is: 



Nemazie-01 



7 



KXFKiiSS MAIL NU.: h;KJi:)lU456^2U:S 



CLAIM 



1 1 . A switching network comprising: 

2 a) a first stage of switches having input lines and output lines and comprising 

3 m (n X k) switches, wherein m is an integer number, n is an integer number 

4 representing the nxmiber of input lines and k is an integer number representing the 

5 number of output lines 

6 b) a second stage of switches comprising of m (k' x k') switches, k' is an integer 

7 number representing the number of inputs and outputs 

8 c) a third stage of switches comprising of m (k x n) switches 

9 wherein k' is selected such that m*Q(k7m) > k (where Q(x/y) denotes the quotient of 
1 0 dividing x by y) to allow using m switches in the second stage. 

„ J 2. A switching network comprising: 

\32. m identical modules, said module further comprising 

a) an input stage comprising of a (n x k) switch wherein n is an integer number 
representing the number of input lines and k is an integer number representing 

" B the number of output lines 

.6 b) a middle stage comprising of a (k' x k') switch, k' is an integer number 

J; y representing the number of inputs and outputs 

r ^JB c) an output stage comprising of a (k x n) switch 

i;;^ wherein k, k', and m satisfy m*Q(k'/m)> k 

1 3 . A method of constructing a switching network comprising: 

2 a) using m identical modules, 

3 b) constructing said module from an input stage comprising of a (n x k) switch, a 

4 middle stage comprising of a (k' x k') switch, an output stage comprising of a 

5 (k X n) switch 

6 c) selecting k' such that m*Q(kVm) > k 

1 4, A module comprising: 

2 a) an input stage comprising of a (n x k) switch, switch wherein n is an integer 

3 number representing the number of input lines and k is an integer number 

4 representing the number of output lines 
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5 b) a middle stage comprising of a (k' x k') switch, k' is an integer number 

6 representing the number of inputs and outputs 

7 c) an output stage comprising of a (k x n) switch 

8 wherein a switching network can be constructed using m of said modules, where k, k', and m 

9 satisfy m*Q(kVm)> k 



1 5. A method of constructing a v(k, n, m) switching network for values of m belonging to a 

2 non-empty set ^ comprising: 

3 a) using m identical modules, 

4 b) constructing said module from an input stage comprising of a (n x k) switch, a 

5 middle stage comprising of a (k' x k') switch, an output stage comprising of a 

6 (k X n) switch 

7 c) selecting k' such that m*Q(kVm) > k for all values of m belonging to set ^ 



Nfima7ifi-01 



0 



bAFKEts^S MAIL NO.: bK851U466:)2UJS 

ABSTRACT 

An embodiment of the present invention is disclosed to include a three stage scalable 
switching network that can be built from a common module. Further disclosed are methods 
for building switchmg network v(k, n, m) from a common module comprising a (n x k) input 
switch, a (k' x k') middle switch, and a (k x n) output switch.. 
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HI is attached hereto 

□ was filed on as Application Serial No. 

and was amended on (if applicable). 

I hereby state that I have reviewed and understand the contents of the above identified specification, including the 
claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the examination of this application in accordance 
with Title 37, Code of Federal Regulations, § L56(a). 

I hereby claim foreign priority benefits under Title 35, United States Code, § 1 19 of any foreign application(s) or U.S. 
provisional application(s) for patent or inventor's certificate listed below and have also identified below any foreign application 
or U.S. provisional application(s) for patent or inventor's certificate having a filing date before that of the application of which 
priority is claimed. 

Prior Foreign/U.S. Provisional Application(s) 



Priority Claimed 



(Number) 


(Country) 


(Day, month, year filed) 


Yes 


No 


(Number) 


(Country) 


(Day, month, year filed) 


Yes 


No" 


(Number) 


(Country) 


(Day, month, year filed) 


Yes 


N^ 



I hereby claim the benefit under Title 35, United States Code, § 120 of any United States application(s) listed below 
and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States application in 
the manner provided by the first paragraph of Title 35, United States Code, § 112, 1 acknowledge the duty to disclose material 
information as defined in Title 37, Code of Federal Regulations, § 1.56(a) which occurred between the filing date of the prior 
application and the national or PCT international filing date of this application: 



(Application Serial No.) Filing Date (Status: Patented, pending, abandoned) 



(Application Serial No.) Filing Date (Status: Patented, pending, abandoned) 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge that willful false 
statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United 
States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon. 

And I hereby appoint MARYAM IMAM Reg. 38,190 of IMAM & ASSOCIATES, Two North Second St., Suite 1 100, 
San Jose, CA 95113 (408)271-8752, as my attorneys with full power of substitution and revocation, to prosecute said 
application and to transact in connection therewith all business in the Patent and Trademark Office and before competent 
International Authorities. 
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Address all wicphone caU$ lo Maryam Imam M (408) 27! -8752 and address all ooncspondcncc to: 

Maryam Imam, Esq. 
IMAM & ASSOCIATES 
Two Nonh Second St., Siiiie I JOO 
San Jose, Caiifoniia 95 U 3 

Wlicrefore i pray that Letters Patent be granted to me for ihe inveiuion or discovery described and claimed in the 
foregoing specification -and claim:*, and I hereby subscribe ray name to the foregoing spccificalion and claims, dcclaraLion. power 
of actorncy. and this petition. 



Full Name of Sole or First Inventor: Siamack Nemazie 



Home Address; 1253 Quail Creek Circle 

Post Office Address: Same as above 

Citizenship: jjaitcd State$ 

Inventor's Signature: O^ - Date: ^/^^/z 
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